# Výstupní zpráva

Jméno: Dmitrii Ivanushkin

Login: xivanu00

# Architektura navrženého obvodu (na úrovni RTL)

#### Schéma obvodu



### Popis funkce

### Prvky UART obvodu jsou:

- FSM, který je detailně popsán níže.
- Čítač counter\_cycle potřebujeme pro správné nalezení MID bitu a posílaní hodnoty do FSM. Podmínky resetu jsou popsány níže, navíc resetujeme pokud není CYCLE\_EN. Inkrementace povolí CYCLE\_EN pokud:
  - 1. CNT\_CYCLE != 8 a zároveň není nastaven BIT\_EN. Jinak resetujeme.
    - 1.1. Tato podmínka znamená, že pokud se nacházíme ve stavu WAIT\_FIRST (poznáme pomocí BIT\_EN) musíme počkat 8 cyklů, resetovat a můžeme inkrementovat CNT\_CYCLE znovu.
  - 2. CNT\_CYCLE != 16 a zároveň je nastaven BIT\_EN. Jinak resetujeme.
    - 2.1. Tato podmínka znamená, že pokud se nacházíme ve stavu READ\_DATA (poznáme pomocí BIT\_EN) musíme počkat 16 cyklů, resetovat a můžeme inkrementovat CNT\_CYCLE znovu.
- Pomocí čítače counter\_bit předáváme číslo načtených bitů do FSM a v DEMUX (jako selektor). Resetujeme pokud není BIT\_EN. Inkrementaci povolí BIT\_EN pokud CNT\_CYCLE == 16
- Demultiplexor p\_demux\_reg, který na základě čísla bitu (CNT\_BIT) přirazí DIN do místa ve vektoru DOUT. Navíc moment zápisu DIN musí být přesně v 16 cyklu (CNT\_CYCLE)

# **Návrh automatu (Finite State Machine)**

#### Schéma automatu

### Legenda:

- Stavy automatu: IDLE, WAIT\_FISRT, READ\_DATA, STOP\_READ
- Vstupní signály: DIN, CNT\_CYCLE [4:0], CNT\_BIT [3:0]
- Moorovy výstupy: DOUT\_VLD, CYCLE\_EN, BIT\_EN



#### Popis funkce

FSM je ve stavu čekání IDLE buď po RST nebo hned po ukončení STOP\_READ. FSM čeká pokud DIN nebude 0, což znamená, že je to start a přecházíme do stavu WAIT\_FIRST

WAIT\_FIRST bude čekat na START bit, který můžeme načíst po 8 cyklů a přejít do stavu READ\_DATA. Výstup CYCLE\_EN je teď nastaven na 1.

Ve stavu READ\_DATA, máme BIT\_EN nastavený na 1. Následující skok do stavu STOP\_READ nastane když druhý čítač CNT\_BIT oznámí, že máme 8 načtených bitů a navíc CNT\_CYCLE bude mít hodnotu 16 (potřebujeme pro správné načtení MID STOP bitu)

Ve stavu STOP\_READ nastavíme DOUT\_VLD na 1 a pokud DIN bude 1, vrátíme se do stavu IDLE

# Snímek obrazovky ze simulací



Obrázek 1: Program gtkwave. Soubor wave.ctl (První slovo)



Obrázek 2: Simulace (skript uart.sh)